package com.itheima.health.service.impl;

import com.alibaba.dubbo.config.annotation.Service;
import com.github.pagehelper.Page;
import com.github.pagehelper.PageHelper;
import com.itheima.health.constant.RedisConstant;
import com.itheima.health.dao.SetmealDao;
import com.itheima.health.entity.PageResult;
import com.itheima.health.pojo.Setmeal;
import com.itheima.health.service.SetmealService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;
import redis.clients.jedis.JedisPool;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

@Service(interfaceClass = SetmealService.class)
@Transactional
public class SetmealServiceImpl implements SetmealService {

    @Autowired
    SetmealDao setmealDao;

/*    @Autowired
    CheckGroupDao checkGroupDao;

    @Autowired
    CheckItemDao checkItemDao;*/

    @Autowired
    JedisPool jedisPool;

    @Override
    public void add(Setmeal setmeal, Integer[] checkgroupIds) {
        //1：保存套餐，返回套餐ID，封装到setmeal中的id属性
        setmealDao.add(setmeal);
        //2：遍历循环，关联中间表
        if (checkgroupIds != null && checkgroupIds.length>0){
            setSetmealAndCheckgroup(setmeal.getId(),checkgroupIds);
        }
        // 在保存套餐数据的时候，同时向redis中存放数据（目的：用于清除七牛云上的垃圾图片），使用redis的集合方式存放
        jedisPool.getResource().sadd(RedisConstant.SETMEAL_PIC_DB_RESOURCES,setmeal.getImg());
    }

    @Override
    public PageResult findPage(Integer currentPage, Integer pageSize, String queryString) {
        PageHelper.startPage(currentPage,pageSize);
        Page<Setmeal> page = setmealDao.findPage(queryString);
        return new PageResult(page.getTotal(),page.getResult());
    }

    @Override
    public List<Setmeal> findAll() {
        return setmealDao.findAll();
    }

/*  方案一：使用java代码分析逻辑
    @Override
    public Setmeal findById(Integer id) {
        // 1：使用套餐id，查询套餐对象
        Setmeal setmeal = setmealDao.findById(id);
        // 2：使用套餐id，查询检查组集合，封装到checkGroups的List<CheckGroup>中
        List<CheckGroup> checkGroups = checkGroupDao.findCheckGroupsBySetmealId(id);
        // 3：遍历检查组的集合，使用检查组的id，查询对应的检查项的集合
        if(checkGroups!=null && checkGroups.size()>0){
            for (CheckGroup checkGroup : checkGroups) {
                List<CheckItem> checkItems = checkItemDao.findCheckItemsByCheckGroupId(checkGroup.getId());
                checkGroup.setCheckItems(checkItems);
            }
        }
        setmeal.setCheckGroups(checkGroups);
        return setmeal;
    }*/

    // 使用mybatis的映射
    @Override
    public Setmeal findById(Integer id) {
        return setmealDao.findById(id);
    }

    @Override
    public List<Map<String, Object>> getSetmealReport() {
        return setmealDao.getSetmealReport();
    }

    // 遍历循环，向套餐和检查组的中间表关联数据
    private void setSetmealAndCheckgroup(Integer setmealId, Integer[] checkgroupIds) {
        Map<String,Object> map = new HashMap<>();
        for (Integer checkgroupId : checkgroupIds) {
            map.put("setmealId",setmealId);
            map.put("checkgroupId",checkgroupId);
            setmealDao.setSetmealAndCheckgroup(map);
        }
    }
}
